<template>
    <div id="ns-pos-customers" class="shadow-lg rounded-lg w-[95vw] h-[95vh] lg:w-[60vw] flex flex-col overflow-hidden">
        <div class="ns-header p-2 flex justify-between items-center border-b">
            <h3 class="font-semibold">{{ __( 'Customers' ) }}</h3>
            <div>
                <ns-close-button @click="popup.close()"></ns-close-button>
            </div>
        </div>
        <div class="ns-body flex-auto flex p-2 overflow-y-auto">
            <ns-tabs :active="activeTab" @active="activeTab = $event">
                <ns-tabs-item identifier="create-customers" :label="__( 'New Customer' )">
                    <ns-crud-form
                        v-if="userCan( 'nexopos.create.customers' )"
                        @updated="prefillForm( $event )"
                        @save="handleSavedCustomer( $event )"
                        submit-url="/api/crud/ns.customers"
                        src="/api/crud/ns.customers/form-config">
                        <template v-slot:title>{{ __( 'Customer Name' ) }}</template>
                        <template v-slot:save>{{ __( 'Save Customer' ) }}</template>
                    </ns-crud-form>
                    <div v-if="! userCan( 'nexopos.create.customers' )" class="h-full flex-col w-full flex items-center justify-center text-font">
                        <i class="lar la-hand-paper ns-icon text-6xl"></i>
                        <h3 class="font-medium text-2xl">{{ __( 'Not Authorized' ) }}</h3>
                        <p>{{ __( 'Creating customers has been explicitly disabled from the settings.' ) }}</p>
                    </div>
                </ns-tabs-item>
                <ns-tabs-item identifier="account-payment" :label="__( 'Customer Account' )" class="flex" padding="p-0 flex">
                    <div class="flex-auto w-full flex items-center justify-center flex-col p-4" v-if="customer === null">
                        <i class="lar la-frown text-6xl"></i>
                        <h3 class="font-medium text-2xl">{{ __( 'No Customer Selected' ) }}</h3>
                        <p>{{ __( 'In order to see a customer account, you need to select one customer.' ) }}</p>
                        <div class="my-2">
                            <ns-button @click="openCustomerSelection()" type="info">{{ __( 'Select Customer' ) }}</ns-button>
                        </div>
                    </div>
                    <div v-if="customer" class="flex flex-col flex-auto">
                        <div class="flex-auto p-2 flex flex-col">
                            <div class="flex flex-wrap">
                                <div class="px-4 mb-4 w-full">
                                    <h2 class="font-semibold">{{ __( 'Summary For' ) }} : {{ customer.first_name }}</h2>
                                </div>
                                <div class="flex flex-wrap ns-tab-cards -mx-2 w-full">
                                    <div class="px-2 mb-4 w-full md:w-1/4 flex">
                                        <div class="rounded-lg shadow w-full bg-transparent bg-gradient-to-br from-success-secondary to-green-700 p-2 flex flex-col text-white">
                                            <h3 class="font-medium text-lg">{{ __( 'Purchases' ) }}</h3>
                                            <div class="w-full flex justify-end">
                                                <h2 class="font-bold">{{ nsCurrency( customer.purchases_amount ) }}</h2>
                                            </div>
                                        </div>
                                    </div>
                                    <div class="px-2 mb-4 w-full md:w-1/4 flex">
                                        <div class="rounded-lg shadow w-full bg-transparent bg-gradient-to-br from-error-secondary to-red-700 p-2 text-white">
                                            <h3 class="font-medium text-lg">{{ __( 'Owed' ) }}</h3>
                                            <div class="w-full flex justify-end">
                                                <h2 class="font-bold">{{ nsCurrency( customer.owed_amount ) }}</h2>
                                            </div>
                                        </div>
                                    </div>
                                    <div class="px-2 mb-4 w-full md:w-1/4 flex">
                                        <div class="rounded-lg shadow w-full bg-transparent bg-gradient-to-br from-blue-500 to-blue-700 p-2 text-white">
                                            <h3 class="font-medium text-lg">{{ __( 'Wallet Amount' ) }}</h3>
                                            <div class="w-full flex justify-end">
                                                <h2 class="font-bold">{{ nsCurrency( customer.account_amount ) }}</h2>
                                            </div>
                                        </div>
                                    </div>
                                    <div class="px-2 mb-4 w-full md:w-1/4 flex">
                                        <div class="rounded-lg shadow w-full bg-transparent bg-gradient-to-br from-teal-500 to-teal-700 p-2 text-white">
                                            <h3 class="font-medium text-lg">{{ __( 'Credit Limit' ) }}</h3>
                                            <div class="w-full flex justify-end">
                                                <h2 class="font-bold">{{ nsCurrency( customer.credit_limit_amount ) }}</h2>
                                            </div>
                                        </div>
                                    </div>
                                </div>
                            </div>
                            <div class="flex flex-auto flex-col overflow-hidden">
                                <ns-tabs :active="selectedTab" @changeTab="doChangeTab( $event )">
                                    <ns-tabs-item identifier="orders" :label="__( 'Orders' )">
                                        <div class="flex-auto h-full justify-center flex items-center" v-if="isLoadingOrders">
                                            <ns-spinner size="36"></ns-spinner>
                                        </div>
                                        <template  v-if="! isLoadingOrders">
                                            <div class="py-2 w-full">
                                                <h2 class="font-semibold text-font">{{ __( 'Last Purchases' ) }}</h2>
                                            </div>
                                            <div class="flex-auto flex-col flex overflow-hidden">
                                                <div class="flex-auto overflow-y-auto">
                                                    <table class="table ns-table w-full">
                                                        <thead>
                                                            <tr class="text-fontcolor">
                                                                <th colspan="3" width="150" class="p-2 border font-semibold">{{ __( 'Order' ) }}</th>
                                                                <th width="50" class="p-2 border font-semibold">{{ __( 'Options' ) }}</th>
                                                            </tr>
                                                        </thead>
                                                        <tbody class="text-fontcolor">
                                                            <tr v-if="orders.length === 0">
                                                                <td class="border p-2 text-center" colspan="4">{{ __( 'No orders...' ) }}</td>
                                                            </tr>
                                                            <tr v-for="order of orders" :key="order.id">
                                                                <td colspan="3" class="border p-2 text-center">
                                                                    <div class="flex flex-col items-start">
                                                                        <h3 class="font-bold">{{ __( 'Code' ) }}: {{ order.code }}</h3>
                                                                        <div class="md:-mx-2 w-full flex flex-col md:flex-row">
                                                                            <div class="md:px-2 flex items-start w-full md:w-1/4">
                                                                                <small>{{ __( 'Total' ) }}: {{ nsCurrency( order.total ) }}</small>
                                                                            </div>
                                                                            <div class="md:px-2 flex items-start w-full md:w-1/4">
                                                                                <small>{{ __( 'Status' ) }}: {{ order.human_status }}</small>
                                                                            </div>
                                                                            <div class="md:px-2 flex items-start w-full md:w-1/4">
                                                                                <small>{{ __( 'Delivery' ) }}: {{ order.human_delivery_status }}</small>
                                                                            </div>
                                                                        </div>
                                                                    </div>
                                                                </td>
                                                                <td class="border p-2 text-center">
                                                                    <button @click="openOrderOptions( order )" class="rounded-full h-8 px-2 flex items-center justify-center border border-gray ns-inset-button success">
                                                                        <i class="las la-wallet"></i>
                                                                        <span class="ml-1">{{ __( 'Options' ) }}</span>
                                                                    </button>
                                                                </td>
                                                            </tr>
                                                        </tbody>
                                                    </table>
                                                </div>
                                            </div>
                                        </template>
                                    </ns-tabs-item>
                                    <ns-tabs-item identifier="wallet-history" :label="__( 'Wallet History' )">
                                        <div class="flex-auto h-full justify-center flex items-center" v-if="isLoadingHistory">
                                            <ns-spinner size="36"></ns-spinner>
                                        </div>
                                        <template v-if="! isLoadingHistory">
                                            <div class="py-2 w-full">
                                                <h2 class="font-semibold text-font">{{ __( 'Wallet History' ) }}</h2>
                                            </div>
                                            <div class="flex-auto flex-col flex overflow-hidden">
                                                <div class="flex-auto overflow-y-auto">
                                                    <table class="table ns-table w-full">
                                                        <thead>
                                                            <tr class="text-fontcolor">
                                                                <th colspan="3" width="150" class="p-2 border font-semibold">{{ __( 'Transaction' ) }}</th>
                                                            </tr>
                                                        </thead>
                                                        <tbody class="text-fontcolor">
                                                            <tr v-if="walletHistories.length === 0">
                                                                <td class="border p-2 text-center" colspan="3">{{ __( 'No History...' ) }}</td>
                                                            </tr>
                                                            <tr v-for="history of walletHistories" :key="history.id">
                                                                <td colspan="3" class="border p-2 text-center">
                                                                    <div class="flex flex-col items-start">
                                                                        <h3 class="font-bold">{{ __( 'Transaction' ) }}: {{ getWalletHistoryLabel( history.operation ) }}</h3>
                                                                        <div class="md:-mx-2 w-full flex flex-col md:flex-row">
                                                                            <div class="md:px-2 flex items-start w-full md:w-1/3">
                                                                                <small>{{ __( 'Amount' ) }}: {{ nsCurrency( amount ) }}</small>
                                                                            </div>
                                                                            <div class="md:px-2 flex items-start w-full md:w-1/3">
                                                                                <small>{{ __( 'Date' ) }}: {{ history.created_at }}</small>
                                                                            </div>
                                                                        </div>
                                                                    </div>
                                                                </td>
                                                            </tr>
                                                        </tbody>
                                                    </table>
                                                </div>
                                            </div>
                                        </template>
                                    </ns-tabs-item>
                                    <ns-tabs-item identifier="coupons" :label="__( 'Coupons' )">
                                        <div class="flex-auto h-full justify-center flex items-center" v-if="isLoadingCoupons">
                                            <ns-spinner size="36"></ns-spinner>
                                        </div>
                                        <template v-if="! isLoadingCoupons">
                                            <div class="py-2 w-full">
                                                <h2 class="font-semibold text-font">{{ __( 'Coupons' ) }}</h2>
                                            </div>
                                            <div class="flex-auto flex-col flex overflow-hidden">
                                                <div class="flex-auto overflow-y-auto">
                                                    <table class="table ns-table w-full">
                                                        <thead>
                                                            <tr class="text-fontcolor">
                                                                <th width="150" class="p-2 border font-semibold">{{ __( 'Name' ) }}</th>
                                                                <th class="p-2 border font-semibold">{{ __( 'Type' ) }}</th>
                                                                <th class="p-2 border font-semibold"></th>
                                                            </tr>
                                                        </thead>
                                                        <tbody class="text-fontcolor text-sm">
                                                            <tr v-if="coupons.length === 0">
                                                                <td class="border p-2 text-center" colspan="4">{{ __( 'No coupons for the selected customer...' ) }}</td>
                                                            </tr>
                                                            <tr v-for="coupon of coupons" :key="coupon.id">
                                                                <td width="300" class="border p-2">
                                                                    <h3>{{ coupon.name }}</h3>
                                                                    <div class="">
                                                                        <ul class="-mx-2 flex">
                                                                            <li class="text-xs text-fontcolor px-2">{{ __( 'Usage :' ) }} {{ coupon.usage }}/{{ coupon.limit_usage }}</li>
                                                                            <li class="text-xs text-fontcolor px-2">{{ __( 'Code :' ) }} {{ coupon.code }}</li>
                                                                        </ul>
                                                                    </div>
                                                                </td>
                                                                <td class="border p-2 text-center">{{ getType( coupon.coupon.type ) }}
                                                                    <span v-if="coupon.coupon.type === 'percentage_discount'">
                                                                        ({{ coupon.coupon.discount_value }}%)
                                                                    </span>
                                                                    <span v-if="coupon.coupon.type === 'flat_discount'">
                                                                        ({{ nsCurrency( value ) }})
                                                                    </span>
                                                                </td>
                                                                <td class="border p-2 text-right">
                                                                    <ns-button @click="applyCoupon( coupon )" type="info">{{ __( 'Use Coupon' ) }}</ns-button>
                                                                </td>
                                                            </tr>
                                                        </tbody>
                                                    </table>
                                                </div>
                                            </div>
                                        </template>
                                    </ns-tabs-item>
                                    <ns-tabs-item identifier="rewards" :label="__( 'Rewards' )">
                                        <div class="flex-auto h-full justify-center flex items-center" v-if="isLoadingRewards">
                                            <ns-spinner size="36"></ns-spinner>
                                        </div>
                                        <template v-if="! isLoadingRewards">
                                            <div class="py-2 w-full">
                                                <h2 class="font-semibold text-font">{{ __( 'Rewards' ) }}</h2>
                                            </div>
                                            <div class="flex-auto flex-col flex overflow-hidden">
                                                <div class="flex-auto overflow-y-auto">
                                                    <table class="table ns-table w-full">
                                                        <thead>
                                                            <tr class="text-fontcolor">
                                                                <th width="150" class="p-2 border font-semibold">{{ __( 'Name' ) }}</th>
                                                                <th class="p-2 border font-semibold">{{ __( 'Points' ) }}</th>
                                                                <th class="p-2 border font-semibold">{{ __( 'Target' ) }}</th>
                                                            </tr>
                                                        </thead>
                                                        <tbody class="text-fontcolor text-sm" v-if="rewardsResponse.data">
                                                            <tr v-if="rewardsResponse.data.length === 0">
                                                                <td class="border p-2 text-center" colspan="4">{{ __( 'No rewards available the selected customer...' ) }}</td>
                                                            </tr>
                                                            <tr v-for="reward of rewardsResponse.data" :key="reward.id">
                                                                <td width="300" class="border p-2">
                                                                    <h3 class="text-center">{{ reward.reward_name }}</h3>
                                                                </td>
                                                                <td width="300" class="border p-2">
                                                                    <h3 class="text-center">{{ reward.points }}</h3>
                                                                </td>
                                                                <td width="300" class="border p-2">
                                                                    <h3 class="text-center">{{ reward.target }}</h3>
                                                                </td>
                                                            </tr>
                                                        </tbody>
                                                    </table>
                                                </div>
                                            </div>
                                            <div class="py-1 flex justify-end">
                                                <ns-paginate :pagination="rewardsResponse" @load="loadRewards( $event )"></ns-paginate>
                                            </div>
                                        </template>
                                    </ns-tabs-item>
                                </ns-tabs>
                            </div>
                        </div>
                        <div class="p-2 border-t border-box-edge flex justify-between">
                            <div></div>
                            <div>
                                <ns-button @click="newTransaction( customer )" type="info">{{ __( 'Account Transaction' ) }}</ns-button>
                            </div>
                        </div>
                    </div>
                </ns-tabs-item>
            </ns-tabs>
        </div>
    </div>
</template>
<script lang="ts">

import closeWithOverlayClicked from "~/libraries/popup-closer";
import { nsHttpClient, nsSnackBar } from '~/bootstrap';
import { Popup } from '~/libraries/popup';
import nsPosCustomerSelectPopupVue from './ns-pos-customer-select-popup.vue';
import nsCustomersTransactionPopupVue from './ns-customers-transaction-popup.vue';
import { __ } from '~/libraries/lang';
import nsPosCouponsLoadPopupVue from './ns-pos-coupons-load-popup.vue';
import nsPosConfirmPopupVue from './ns-pos-confirm-popup.vue';
import popupResolver from '~/libraries/popup-resolver';
import popupCloser from '~/libraries/popup-closer';
import nsPaginate from '~/components/ns-paginate.vue';
import nsOrderPreviewPopup from './ns-orders-preview-popup.vue';
import { nsCurrency } from '~/filters/currency';

declare const POS;

export default {
    name: 'ns-pos-customers',
    props: [ 'popup' ],
    data() {
        return {
            activeTab: 'create-customers',
            customer: null,
            subscription: null,
            orders: [],
            options: {},
            optionsSubscriber: null,
            selectedTab: 'orders',
            isLoadingCoupons: false,
            isLoadingRewards: false,
            isLoadingHistory: false,
            isLoadingOrders: false,
            coupons: [],
            userCan: ( permission ) => POS.userCan( permission ),
            rewardsResponse: [],
            order: null,
            walletHistories: [],
        }
    },
    components: {
        nsPaginate
    },
    unmounted() {
        this.subscription.unsubscribe();
        this.optionsSubscriber.unsubscribe();
    },
    mounted() {
        this.closeWithOverlayClicked();

        this.optionsSubscriber  =   POS.options.subscribe( options => {
            this.options    =   options;
        });

        this.subscription   =   POS.order.subscribe( order => {
            this.order  =   order;

            if ( this.popup.params.customer !== undefined ) {
                this.activeTab  =   'account-payment';
                this.customer   =   this.popup.params.customer;
                this.loadCustomerOrders();
            } else if ( order.customer !== undefined ) {
                this.activeTab  =   'account-payment';
                this.customer   =   order.customer;
                this.loadCustomerOrders();
            }
        });

        this.popupCloser();
    },
    methods: {
        __,
        nsCurrency,

        reload() {
            this.loadCustomerOrders();
        },

        popupResolver,
        popupCloser,

        getWalletHistoryLabel( type ) {
            switch( type ) {
                case 'add':
                    return __( 'Crediting' );
                case 'deduct':
                    return __( 'Removing' );
                case 'refund':
                    return __( 'Refunding' );
                case 'payment':
                    return __( 'Payment' );
                default:
                    return __( 'Unknow' );
            }
        },

        getType( type ) {
            switch( type ) {
                case 'percentage_discount':
                    return __( 'Percentage Discount' );
                case 'flat_discount' :
                    return __( 'Flat Discount' );
            }
        },

        closeWithOverlayClicked,

        async openOrderOptions( order ) {
            try {
                const result    =   await new Promise( ( resolve, reject ) => {
                    Popup.show( nsOrderPreviewPopup, {
                        order,
                        resolve,
                        reject
                    });
                });

                this.reload();

            } catch( exception ) {
                nsSnackBar.error( __( 'An error occurred while opening the order options' ) );
            }
        },

        doChangeTab( tab ) {
            this.selectedTab = tab;

            if ( tab === 'coupons' ) {
                this.loadCoupons();
            }

            if ( tab === 'rewards' ) {
                this.loadRewards();
            }

            if ( tab === 'wallet-history' ) {
                this.loadAccounHistory();
            }

            if ( tab === 'orders' ) {
                this.loadCustomerOrders();
            }
        },

        loadAccounHistory() {
            this.isLoadingHistory   =   true;
            nsHttpClient.get( `/api/customers/${this.customer.id}/account-history` )
                .subscribe({
                    next: ( result ) => {
                        this.walletHistories    =   result.data;
                        this.isLoadingHistory   =   false;
                    },
                    error: ( error ) => {
                        this.isLoadingHistory   =   false;
                    }
                });
        },

        loadCoupons() {
            this.isLoadingCoupons   =   true;
            nsHttpClient.get( `/api/customers/${this.customer.id}/coupons` )
                .subscribe({
                    next: ( coupons ) => {
                        this.coupons            =   coupons;
                        this.isLoadingCoupons   =   false;
                    },
                    error: ( error ) => {
                        this.isLoadingCoupons   =   false;
                    }
                });
        },
        
        loadRewards( url = `/api/customers/${this.customer.id}/rewards` ) {
            this.isLoadingRewards   =   true;
            nsHttpClient.get( url )
                .subscribe({
                    next: ( rewardsResponse ) => {
                        this.rewardsResponse            =   rewardsResponse;
                        this.isLoadingRewards   =   false;
                    },
                    error: ( error ) => {
                        this.isLoadingRewards   =   false;
                    }
                });
        },

        prefillForm( event ) {
            if ( this.popup.params.name !== undefined ) {
                event.main.value     =   this.popup.params.name;
            }
        },

        openCustomerSelection() {
            this.popup.close( _ => {
                Popup.show( nsPosCustomerSelectPopupVue );
            });
        },

        loadCustomerOrders() {
            this.isLoadingOrders    =   true;
            nsHttpClient.get( `/api/customers/${this.customer.id}/orders` )
                .subscribe({
                    next: orders => {
                        this.orders     =   orders;
                        this.isLoadingOrders    =   false;
                    },
                    error: e => {
                        this.isLoadingOrders    =   false;
                    }
                });
        },

        newTransaction( customer ) {
            const promise   =   new Promise( ( resolve, reject ) => {
                Popup.show( nsCustomersTransactionPopupVue, { customer, resolve, reject });
            });

            /**
             * let's update the customer
             * with upated reference.
             */
            promise.then( result => {
                POS.loadCustomer( customer.id )
                    .subscribe( _customer => {
                        POS.selectCustomer( _customer );
                    });
            })
        },

        applyCoupon( customerCoupon ) {
            if ( this.order.customer === undefined ) {
                Popup.show( nsPosConfirmPopupVue, {
                    title: __( 'Use Customer ?' ),
                    message: __( 'No customer is selected. Would you like to proceed with this customer ?' ),
                    onAction : ( action ) => {
                        if ( action ) {
                            POS.selectCustomer( this.customer )
                                .then( result => {
                                    this.proceedApplyingCoupon( customerCoupon );
                                })
                        }
                    }
                })
            } else if ( this.order.customer.id === this.customer.id ) {
                this.proceedApplyingCoupon( customerCoupon );
            } else if ( this.order.customer.id !== this.customer.id ) {
                Popup.show( nsPosConfirmPopupVue, {
                    title: __( 'Change Customer ?' ),
                    message: __( 'Would you like to assign this customer to the ongoing order ?' ),
                    onAction : ( action ) => {
                        if ( action ) {
                            POS.selectCustomer( this.customer )
                                .then( result => {
                                    this.proceedApplyingCoupon( customerCoupon );
                                })
                        }
                    }
                })
            }
        },

        proceedApplyingCoupon( customerCoupon ) {
            const promise   =   new Promise( ( resolve, reject ) => {
                Popup.show( nsPosCouponsLoadPopupVue, { apply_coupon : customerCoupon.code, resolve, reject })
            }).then( result => {
                this.popupResolver( false );
            }).catch( exception => {
                // ...
            })
        },

        handleSavedCustomer( response ) {
            nsSnackBar.success( response.message );
            POS.selectCustomer( response.data.entry );
            this.popup.close();
        }
    }
}
</script>
